IMAGE PROCESSING APPARATUS, 
METHOD FOR ADDING OR UPDATING SEQUENCE OF IMAGE PROCESSING 
AND DATA FOR IMAGE PROCESSING IN THE IMAGE PROCESSING APPARATUS , 
AND CCMPUTER-READABLE RECORDING MEDIUM WHERE PROGRAM 
FOR MAKING COMPUTER EXECUTE THE METHOD IS RECORDED 

FIELD OF THE INVENTION 

The present invention relates to an image processing 
apparatus that performs linage processing on digital image data, 
10 particularly, on image data for a digital multifunction machine 
that combines functions of a copier, a facsimile, a printer, and 
a scanner, or the like into one. Further, this invention also 
relates to a method for adding or updating a sequence of image 
processing and data for image processing in the dLmage processing 
15 apparatus, and a computer-readable recording medium where a 
program for making a computer execute the method is recorded. 

RAnKHROUND OF THE INVENTION 

A digital copier that performs processing on digitized image 
20 data appeared on the market following an analog copier, and further, 
there is a digital multifunction machine formed by combining 
functions of a facsimile, a printer, and a scanner with the function 
of the digital copier. 

As a management system of such an image processing apparatus, 
25 there is one that determines that an image processing apparatus 
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is in a state of not working, and performs download, or upload at 
the most suitable time excluding the highest possible time to be 
used, as disclosed in JP, HEX 06-237330 A. 

There is another one, as disclosed in JP, HEX 09-91129 A, 
5 that determines whether a program to be rewritten does not exert 
an influence onto the operation of an image processing apparatus 
even during its operation when the program of the apparatus is to 
be upgraded. Xf it is determined that the operation is not affected, 
the system rewrites the program, and if it is determined that the 
10 operation is affected, the system puts rewriting on hold until the 
I'ri operation is finished. 

Xn the management system disclosed in JP, HEX 06-237330 A, 
13 however, the execution of alteration of or addition to a program 

Q is limited to a state where the image processing apparatus is not 

13 15 working. Accordingly, it is iirpossible to provide an image 

E3 processing apparatus with high efficiency and availability. Thus, 

alteration of or addition to the program can not be executed 
immediately when it is required. 

Further, in the management system disclosed in JP, HEX 
20 09-9X129 A, its main purpose is upgrade of a program. Therefore, 
if the program is rewritable, rewriting is performed. However, 
if rewriting is not allowed, some system puts rewriting on hold, 
which is quite iirpossible to enhance the efficiency of parallel 
operation of the image processing apparatus. Accordingly, more 
25 efficiency of the operation is needed to provide an image processing 



apparatus with high efficiency and availability. 

.qiTMMARY OF TH E INVENTION 

It is an object of this invention to provide an image 
5 processing apparatus with high efficiency and availability that 
efficiently performs alteration of or addition to a program 
immediately when it is required without interruption of the primary 
operation of the image processing apparatus. The object of this 
invention is also to provide a method for adding or updating a 

10 sequence of image processing and data for image processing in the 
image processing apparatus, and to provide a coirputer-readable 
recording medium where a program for making a cortputer execute the 
method is recorded. 

According to one aspect of this invention, during idle cycle 

15 time that an image processing section does not execute image 
processing, a transfer control section splits a sequence of image 
processing and data for image processing to be added or updated 
into blocks for a plurality of transfer times, and transfers the 
blocks from the third storage section to the second storage section. 

20 Further, during the idle cycle time that the image processing 

section does not execute image processing, the transfer control 
section splits the sequence of image processing and data for image 
processing to be added or updated into blocks for a plurality of 
transfer times each by a predetermined number of pieces of data 

25 to be transferred for one time, and transfers the blocks from the 
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third storage section to the second storage section. 

Further^ a set value of the number of pieces of data to be 
transferred for one time is included in data downloaded from the 
external microprocessor into the third storage section, and is set 
according to the length of idle cycle time determined based on the 
ability of the image processing section to perform image 
processing. 

Further, an image processing unit is formed with an SIMD 
type of processor to perform image processing based on a high- 
speed coitputation of the SIMD type of processor. 

According to another aspect of this invention, a sequence 
of image processing and data for image processing to be added or 
updated are split into blocks for a plurality of transfer times, 
and the blocks are transferred from a third storage section to a 
second storage section during idle cycle time that an image 
processing section does not execute image processing. 

Further, the sequence of image processing and data for image 
processing to be added or updated are split into blocks for a 
plurality of transfer times each by a predetermined number of pieces 
of data to be transferred for one time, and the blocks are 
transferred from the third storage section to the second storage 
section during the idle cycle time that the image processing section 
does not execute image processing. 

Further, a set value of the number of pieces of data to be 
transferred for one time is included in data downloaded from the 




external microprocessor into the third storage section, and is set 
according to the length of idle cycle time determined based on the 
ability of the image processing section to perform image 
processing. 

5 According to still another aspect of this invention, a 

program which makes a coirputer execute the method according to the 
invention is recorded in a recording medium, which allows the 
program to be machine -readable . Accordingly, the method according 
to the invention can be executed by a computer , 

10 Other objects and features of this invention will become 

understood from the following description with reference to the 
acconpanying drawings . 

Other objects and features of this invention will become 
understood from the following description with reference to the 

15 accompanying drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 is a block diagram functionally showing a 
configuration of an image processing apparatus according to an 
20 embodiment of this inventions- 
Fig. 2 is a block diagram showing an example of the 
configuration of hardware in the image processing apparatus 
according to this embodiments- 
Fig . 3 is a block diagram showing another exairple of the 
25 configuration of the hardware in the image processing apparatus 




according to the embodiments- 
Fig. 4 is a block diagram showing a general outline of 

processing in an image processor for the image processing apparatus 

according to the embodiment; 
5 Fig. 5 is a block diagram showing an internal configuration 

of the image processor for the image processing apparatus according 

to the embodiment; 

Fig. 6 is a block diagram showing a general outline of 

processing for updating the contents of program RAM and data RAM 
10 in the image processor for the image processing apparatus according 

to the embodiment; 

Fig. 7 is a flow chart showing a process flow of updating 

the contents of the program RAM and the data RAM in the image 

processor for the image processing apparatus according to the 
1 5 embodiment ; 

Fig. 8 shows a data format for updating the contents of the 

program RAM and the data RAM in the image processor for the image 

processing apparatus according to the embodiment; 

Fig. 9 is a block diagram showing a general outline of 
20 processing in an image data control section for the image processing 

apparatus according to the embodiment; 

Fig. 10 is a block diagram showing a general outline of 

processing for video data in the image processing apparatus 

according to the embodiment; 
25 Fig. 11 is a block diagram showing a general outline of 



processing of the image -memory access control section in the image 
processing apparatus according to the embodiment; 

Fig. 12 is a block diagram showing an example of a 
configuration of units in the image processing apparatus according 
to the embodiment; 

Fig. 13 is a block diagram showing another exait^le of the 
configuration of units in the image processing apparatus according 
to the embodiment; 

Fig. 14 schematically shows a scanner (an example of a 
spatial filter) in the image processing apparatus according to the 
embodiment; 

Fig. 15 schematically shows shading correction in the image 
processing apparatus according to the embodiment; 

Fig. 16 schematically shows shading data in the image 
processing apparatus according to the embodiment; 

Fig. 17 shows an example of a data flow of image data in 
the image processing apparatus according to the embodiment; 

Fig. 18 shows another example of the data flow of image data 
in the image processing apparatus according to the embodiment; 

Fig. 19 shows another exaxrple of the data flow of image data 
in the image processing apparatus according to the embodiment; 

Fig. 20 shows another example of the data flow of image data 
in the image processing apparatus according to the embodiment; 

Fig. 21 is a block diagram showing a configuration of a 
facsimile control unit in the image processing apparatus according 



to the embodiment; and 

Fig. 22 schematically shows a configuration of an SIMD type 
of processor used in the image processing apparatus according to 
the embodiment. 

5 

DESCRIPTION OF THE PRF.FERRED EMBODIMENT 

A preferred embodiment of the image processing apparatus, 
the method for adding or updating a sequence of image processing 
and data for image processing in the image processing apparatus/ 
10 and the corrputer-readable recording medium where a program for 
making a computer execute the method is recorded according to this 
invention is explained blow with reference to the attached 
drawings . 

Principles of the image processing apparatus according to 
15 this embodiment are explained. Fig. 1 is a block diagram 
functionally showing a configuration of the image processing 
apparatus according to the embodiment of this invention. As shown 
in Fig. 1, the image processing apparatus comprises five units as 
follows . 

20 The five units are an image data control unit 100, an image 

reading unit 101 that reads image data, an image memory control 
unit 102 that controls image memory for accumulating images to 
execute reading /writing of image data, an image processing unit 
103 that subjects the image data to image processing such as editing 

25 or the like, and an image writing unit 104 that writes the image 



data onto transfer paper or the like. 

The image data control unit 100 is arranged at the center 
of the units . That is, the image reading unit 101, the image memory 
control unit 102, the image processing unit 103, and the image 
5 writing unit 104 are connected to the image data control unit 100, 
respectively. 

[Image data control unit 100] 

The processing executed by the image data control unit 100 

includes those as follows. For example: 
^3 10 (1) Data compression to irrprove data transfer efficiency on the 

^L! bus (Primary coirpression) 

J^^' (2) Transfer of the primarily compressed data to image data 

(3) Image synthesis (Image data from a plurality of units can 
be synthesized. The synthesis also includes image synthesis on 

=^ 

12 15 the data bus.) 

(4) Image shift (Shift of an image in a main scanning direction 
and an auxiliary scanning direction) 

(5) Expansion of an image area (Image area can be expanded to 
its periphery by an arbitrary amount.) 

20 (6) Image scaling (Fixed scaling of 50% or 200%, for exairple) 

(7) Parallel bus/interface processing 

(8) Serial bus/interface processing (Interface to a process 
controller 211 explained later) 

(9) Conversion of formats between parallel data and serial data 
25 (11) Interface processing to the image reading unit 101 



(12) Interface processing to the image processing unit 103 
[Image reading unit 101] 

The processing executed by the image reading unit 101 
includes those as follows. For example: 

(1) Scanning light reflected off a document by an optical system 

(2) Conversion of data to electric signals in CCD (Charge Coupled 
Device ) 

(3) Digitization in the A/D converter 

(4) Shading correction (Correction to nonunif ormity in 
illumination distribution of a light source) 

(5) Scanner y -correction (Correction to density 
characteristics in the scanning system) 

[Image memory control unit 102] 

The processing executed by the image memory control unit 
102 includes those as follows. For example: 

(1) Interface control to the system controller 

(2) Parallel bus control (Interface control to the parallel bus) 

(3) Network control 

(4) Serial bus control (Control for a plurality of external 
serial ports) 

(5) Internal bus interface control (Control for commands with 
the operation section) 

(6) Local bus control (Control for access to ROM, RAM, and font 
data to, start up the system controller) 

(7) Operation control for the memory module (Write/read 




controls for the memory module, or the like) 

(8) Control for access to the memory module (Processing for 
controlling memory access requests from a plurality of units) 

(9) Data coirpression/decoirpression (Processing for reducing 
5 data amounts to effectively utilize the memory) 

(10) Image editing (Clearing of data in a memory area, rotation 
of image data, and image synthesis on the memory, or the like) 
[Image processing unit 103] 

The processing executed by the image processing unit 103 
■-3 10 includes those as follows. For example: 

ijj (1) Shading correction (Correction to nonunif ormity in 

illumination distribution of the light source) 

(2) Scanner y -correction (Correction to density 
"5 characteristics in the scanning system ) 

I'l 15 (3) MTF correction 

£3 ( 4 ) Smoothing 

(5) Scaling to an arbitrary size in the main scanning direction 

(6) Density conversion ( y conversion: corresponding to a 
density notch) 

20 (7) Simple multi-valued processing 

(8) Simple binary processing 

(9) Error diffusion 

(10) Dithering 

(11) Phase control for dot arrangement (dots aligned on the right, 
25 dots aligned on the left) 



(12) Removal of isolated points 

(13) Separation of image area (Determination of color, 
determination of an attribute, other processing for the 
separation) 

5 (14) Density conversion 
[Image writing unit 104] 

The processing executed by the image writing unit 104 
includes those as follows. For example: 
(1) Edge smoothing (Jaggy correction) 
^^3 10 (2) Correction for re-arrangement of dots 

in (3) Pulse control for image signal 

^-3 (4) Format conversion between parallel data and serial data 

§ pt 

^=^' [Hardware configuration of digital multifianction machine] 

^% The configuration of hardware when the image processing 

15 apparatus according to this embodiment forms the digital 
f| multifunction machine is explained below. Fig. 2 is a block 

diagram showing an exairple of the configuration of the hardware 
in the image processing apparatus according to this embodiment. 

As shown in the block diagram of Fig. 2, the image processing 
20 apparatus according to this embodiment corrprises a scanning unit 
201, a sensor board unit 202, an image data control section 203, 
an image processor (image processing unit) 204, a video data control 
section 205, and an image formation unit (engine) 206. The image 
processing apparatus according to the embodiment also comprises 
25 a process controller 211, RAM 212, and ROM 213 via a serial bus 



210. 

The image processing apparatus according to the embodiinent 
further conprises an image-memory access control section 221, a 
memory module 222, a facsimile control unit 224, and a system 
controller 231, RAM 232, ROM 233 and an operating panel 234 which 
are connected to the image -memory access control section 221, each 
connected via a parallel bus 220. 

A relation between the components and the respective units 
100 to 104 as shown in Fig. 1 is explained below. That is, the 
function of the image reading unit 101 shown in Fig. 1 is performed 
by the scanning unit 201 and the sensor board unit 202 . The function 
of the image data control unit 100 is performed by the image data 
control section 203 . Further, the function of the image processing 
unit 103 is performed by the image processor 204. 

The image writing unit 104 is formed with the video data 
control section 205 and the image formation unit (engine) 206. The 
image memory control lonit 102 is formed with the image-memory access 
control section 221 and the memory module 222. 

The contents of each component is explained below. The 
scanning unit 201, that optically scans a document, coirprises a 
lamp, a mirror, and a lens. Reflection light of the light 
irradiated from a lamp to the document is converged to a 
photoreceptor through the mirror and the lens. 

The photoreceptor such as a CCD is mounted on the sensor 
board unit 202. The image data converted to electric signals in 




the CCD is converted to digital signals, and is output (transmitted) 
from the sensor board unit 202. 

The image data output (transmitted) from the sensor board 
unit 202 is input (received) into the image data control section 
5 203. The image data control section 203 controls overall 
transmission of the image data between functional devices 
(processing units) and data buses. 

The image data control section (image data/interface 
control section) 203 performs image-data transfer between the 

10 sensor board unit 202 , the parallel bus 220 , and the linage processor 
204, and also performs image-data communications between the 
process controller 211 and the system controller 231 that controls 
the overall image processing apparatus. The RAM 212 is used as 
a work area of the process controller 211, and the ROM 213 stores 

15 a boot program or the like of the process controller 211. 

The image processor 204 is a programmable coitputation unit 
that performs image processing. The image data output 
(transmitted) from the sensor board unit 202 is transferred 
(transmitted) to the image processor 204 through the image data 

20 control section 203. Signal degradation (signal degradation in 
a scanner system) due to the optical system and during quantization 
of the image data to digital signals is corrected in the image 
processor 204, and the corrected signals are output (transmitted) 
to the image data control section 203 again. 

25 The image-memory access control section 221 controls 
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writing and reading of the image data in and from the memory module 
222. The system controller 231 controls operations of the 
respective components connected to the parallel bus 220. The RAM 
232 is used as a work area of the system controller 231, and the 
5 ROM 233 stores a boot program or the like of the system controller 
231. 

The processing that has to be done by the image processing 
apparatus is entered through the operating panel 234 . For exairple, 
a type of processing (copying, facsimile transmission, image 
-^3 10 scanning, or printing) and a number of copies to be processed are 

^2 entered through the operating panel 234. Accordingly, control 

;f information for the image data can be input. The contents of the 

facsimile control unit 224 will be explained later, 
''i The processing for the image data scanned by the scanning 

il 15 unit 201 includes a job that accumulates the scanned linage data 

£3 

tj in the memory module 222 and reuses the data and a job that does 

not acciamulate the data in the memory module 222. The respective 
cases are explained below. 

As an exarrple of accumulating the scanned image data in the 

20 memory module 222, there is a case of making a plurality copies 
of a sheet of document. In this case, the scanning unit 201 is 
operated only once, the image data scanned by the scanning unit 
201 is accumulated in the memory module 222, and the image data 
accumulated in the memory module 222 is read out a plurality of 

25 times. 




As an example of not using the memory module 222, there is 
a case of making only a copy of a sheet of document. In this case, 
the scanned image data may be reproduced as it is . Accordingly, 
there is.no need for the image-memory access control section 221 
5 to access the memory module 222. 

When the memory module 222 is not used, the data transferred 
from the image processor 204 to the image data control section 203 
is returned again from the image data control section 203 to the 
image processor 204. The image processor 204 performs the 

10 processing for image quality to convert the brightness data 
obtained by the CCD in the sensor board unit 202 to area gradation. 

The image data whose image quality has been processed is 
transferred from the image processor 204 to the video data control 
section 205. The video data control section 205 provides pulse 

15 controls for the signals converted to the area gradation in order 
to perform post-processing for dot arrangement and reproduce the 
dots. The image data is then transmitted to the image formation 
unit 206, which forms a reproduction image on transfer paper. 

A flow of image data is explained below. More specifically, 

20 the flow of image data shows the case where image data is accumulated 
in the memory module 222 and additional processing, such as rotation 
of an image direction or synthesis of images, is performed at the 
time of reading out the images. The image data transferred from 
the image processor 204 to the image data control section 203 is 

25 sent from the image data control section 203 to the image-memory 
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access control section 221 through the parallel bus 220. 

This image-memory access control section 221 provides 
controls for accesses to the image data and the memory module 222, 
and performs decompression of data for printing of an external PC 
(personal coitputer) 223, and compression or decorr^^ression of the 
image data to make effective use of the memory module 222, 

The image data sent to the image-memory access control 
section 221 is accumulated in the memory module 222 after the data 
is compressed, and the accumulated image data is read out as 
required. The read-out image data is decompressed and restored 
to the original image data, and the data is returned from the 
image-memory access control section 221 to the image data control 
section 203 through the parallel bus 220. 

The image data after transferred from the linage data control 
section 203 to the image processor 204 is subjected to processing 
for image quality and is pulse-controlled in the video data control 
section 205 to form a reproduction image on transfer paper in the 
image formation unit 206. In the flow of image data, the functions 
of the digital multifunction machine are performed through the 
parallel bus 220 and based on bus control provided by the image 
data control section 203. 

Facsimile transmission is perfomed by executing image 
processing on the read-out image data in the image processor 204 
and transferring the image data to the facsimile control unit 224 
through the image data control section 203 and the parallel bus 



220. The facsimile control unit 224 converts the data to that for 
a coinmunication network and transmits the converted data as 
facsimile data to a public network (PN) 225. 

Facsimile reception is carried out by converting the network 
data from the p\ablic network (PN) 225 to image data in the facsimile 
control unit 224 and transferring the data to the image processor 
204 through the parallel bus 220 and the image data control section 
203. In this case, specific processing for image quality is not 
performed on the data, but the video data control section 205 
performs re-arrangement of dots and pulse controls, and the image 
formation unit 206 forms a reproduction image on transfer paper. 

There are a plurality of jobs, such as a copying function, 
a facsimile transmission/ reception function, and a printer output 
function. Under the situation that the plurality of jobs operate 
in parallel, the system controller 231 and the process controller 
211 provide controls for allocation of accesses by the scanning 
unit 201, the image formation unit 206, and the parallel bus 220 
to the respective jobs. 

The process controller 211 controls the flow of image data, 
and the system controller 231 controls the overall system to manage 
starting of resources. Selection of the functions of the digital 
multifunction machine is executed in the operating panel 
(operation section) 234, and contents of processing such as the 
copying function or the facsimile function are set by selecting 
and entering any of the functions through the operating panel 
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(operation section) 234. 

The system controller 231 and the process controller 211 
performs interactive communications through the parallel bus 220, 
the image data control section 203, and the serial bus 210. More 
5 specifically, communications between the system controller 231 and 
the process controller 211 are performed by converting data formats 
to each other for data interfaces between the parallel bus 220 and 
the serial bus 210 in the image data control section 203. 
[Hardware configuration of scanner as discrete device] 
10 A configuration of hardware when the image processing 

i'^^ apparatus according to the embodiment forms a scanner as a discrete 

f 3 device is explained blow . Fig . 3 is a block diagram showing another 

12 exairple of the hardware configuration of the image processing 

tj apparatus according to the embodiment. The same reference 

£3 15 numerals are assigned to the components corresponding to those in 

C3 the block diagram of the hardware configuration shown in Fig. 2 

C3 

and explanation of the corrponents is omitted. 

In the system configuration of the hardware, a big difference 
between the discrete scanner shown in Fig. 3 and the digital 
20 multifunction machine shown in Fig. 2 is that the discrete scanner 
has no image formation unit 206. There is no need to provide the 
image formation unit 206, therefore, the video data control section 
205 is not mounted on the scanner as well. 

The image data scanned in the scanning unit 201 is converted 
25 to digital data in the sensor board unit 202, and is transferred 
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to the image processor 204 via the image data control section 203. 
The image processor 204 then performs image processing required 
as a discrete scanner on the data. 

The main linage processing required as a discrete scanner 
is correction to degradation in the scanned image. The image 
processor 204 can also perform gray-scale processing adequate for 
a display unit using a screen. Accordingly, the processing is 
different in many ways from the processing for image quality 
targeting the transfer paper. 

The image processor 204 is formed with the programomble 
computation unit. Therefore, only the sequence of processing, 
that is required for the processing for image quality suitable for 
the transfer paper and gray-scale processing to the screen, may 
be set. Thus, there is no need to provide both the sequence of 
image-quality processing and the sequence of gray-scale processing 
all the time. 

The image data on which the gray-scale processing is 
performed is transferred to the image data control section 203 and 
is transmitted to the image-memory access control section 221 
through the parallel bus 220. The function of the scanner is 
performed here by using the memory module 222 as buffer memory and 
transferring image data to a driver that accompanies a PC 223. 

In this case, the system controller 231 and the process 
controller 211 also manage the image data and the resources of the 
system in the same manner as that of the digital multifunction 




machine . 

[Image processing unit 103/Image processor 204] 

A general outline of the processing in the image processor 
204 that forms the image processing unit 103 is explained below. 
5 Fig. 4 is a block diagram showing the general outline of the 
processing in the linage processor 204 for the image processing 
apparatus according to the embodiment. 

As shown in the block diagram of Fig. 4, the image processor 
204 coitprises a first input I/F 401, a scanner imaging section 402, 
10 a first output I/F 403, a second input I/F 404, an image quality 
processing section 405, a second output I/F 406, and a command 
control section 407. 

Based on the configuration, the scanned image is transferred 
from the first input interface (I/F) 401 of the image processor 
15 204 to the scanner imaging section 402 via the sensor board unit 
202 and the image data control section 203. 

The purpose of scanner imaging performed in the scanner 
imaging section 402 is to correct degradation in the scanned image 
data. More specifically, shading correction, scanner y - 
20 correction, and MTF correction, or the like are performed. Further, 
scaling such as enlargement or reduction of the image size can also 
be performed although it is not the processing for correction. 
When the correction to the scanned image data is completed, the 
image data is transferred from the first output interface (I/F) 
25 403 to the image data control section 203. 
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When the image data is to be output onto the transfer paper, 
the second input I/F 404 receives the image data from the image 
data control section 203, and the image quality processing section 
405 performs the processing for area gradation on the data. The 
5 image data on which the image quality processing is performed is 
output to the video data control section 205 or the image data 
control section 203 via the second output I/F 406. 

The processing for area gradation in the image quality 
processing section 405 includes the processing for density 
^-3 10 conversion, dithering, and error diffusion or the like. That is, 

the main processing of all is to obtain an approximation of the 
fi area based on the gradation information. 

Once the image data processed by the scanner imaging section 
402 is accumulated in the memory module 222, variations of 
11 15 reproduction image can be obtained by changing the processing for 

£3 image quality by the image quality processing section 405. 

For example, diffusing (altering) the density of a 
reproduction image or altering the number of lines of a dither 
matrix allows the feel of the reproduction image to easily be 
20 changed. In this case, there is no need to restart reading in the 
image from the scanning unit 201 each time the processing is changed. 
Therefore, different processing can quickly be executed to the same 
image data any niomber of times by reading out the accumulated image 
data from the memory module 222 . 
25 In the case of the discrete scanner, both the scanner imaging 




and the gray-scale processing are performed on the data, and the 
data is output to the image data control section 203. The contents 
of the processing can be altered in a programmable manner. 
Selection of the processing and alteration of the sequence of the 
5 processing or the like are managed in the command control section 
407 via a serial I/F 408. 

An internal configuration of the image processor 204 is 
explained below. Fig. 5 is a block diagram showing the internal 
configuration of the image processor 204 in the image processing 

10 apparatus according to the embodiment. The image processor 204 
has a plurality of input /output ports 501 for data input /output 
to/ from the outside, each in which arbitrary setting can be made 
for input or output of data, respectively. 

The image processor 204 has a group of bus switches/local 

15 memories (first storage section) 502 internally provided for 
connection to the input /output ports 501, and a memory control 
section 503 controls a memory area and a data path to be used. The 
group of bus switches/local memories 502 are allocated as buffer 
memories to input data and data to be output, and the data is stored 

20 in the respective memories, thus interface to the outside is 
controlled. 

A processor array section (image processing section) 504 
performs various processing for the image data stored in the group 
of bus switches/local memories 502, and stores again the result 
25 of output (processed image data) in the group of bus switches /local 
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memories 502 . 

The sequence of processing and the parameters for the 
processing in the processor array section 504 are exchanged between 
program RAM 505 and data RAM 506 (second storage section) that can 
5 be referred to by a unit for controlling data processing in the 
processor array section 504. 

The contents of the program RAM 505 and the data RAM 506 
are downloaded from the process controller 211 into a host buffer 
(third storage section) 507 via a serial I/F 508, are timing- 

10 controlled by the host buffer 507, and then the contents are updated 
with the downloaded ones. The process controller 211 reads out 
the contents of the data RAM 506, that has been timing-controlled 
and read out by the host buffer 507, onto the host buffer 507 and 
monitors how the processing is going on based on the contents. 

15 The case, that the contents of the processing is to be altered 

or the form of processing required in the system is to be altered, 
is dealt with by updating the contents of the program RAM 505 and 
the data RAM 506 that the processor array section 504 refers to. 

The operation of updating the contents of the program RAM 

20 505 and the data RAM 506 is explained in detail below with reference 
to Fig. 6. It is assumed here that the current operation of this 
apparatus is copying. More specifically, in this apparatus, the 
image signals scanned by the scanning unit 201 are processed along 
the flow as follows to form a reproduction image : the image data 

25 control section 203 image processor 204 image data control 
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section 203 image processor 204 -> video data control section 
205 — > image formation unit 206. 

If a facsimile reception request comes up, the process 
controller 211 transfers the sequence of processing and the data 
5 for the processing required for facsimile reception from the ROM 
213, that is provided near to the controller, to the host buffer 
507 of the image processor 204 via the serial I/F 508. The process 
controller 211 notifies a transfer control section 601 in the image 
processor 204 of the end of the transfer with a transfer-end signal . 
;3 10 When the transfer-end signal is received, the transfer 

control section 601 checks a busy signal from the processor array 
?f section 504. If this signal is inactive, the transfer control 

section 601 determines that the processor array section 504 is not 
,^5 used for computation based on a computation control signal output 

lI 15 by a corrputation control section 602. That is, the transfer 

;3 control section 601 determines that the processor array section 

504 is during idle cycle time that the processor array section 504 
does not execute image processing. The transfer control section 
601 then switches from the connection of the program RAM 505 or 
20 the data RAM 506 with the processor array section 504 to the 
connection thereof with the host buffer 507 by a switching section 
603 or 604. 

The data in the host buffer 507 starts to be transferred 
to either of the RAMs via the serial I/F 508 at a speed higher than 
25 the transfer speed between the host buffer 507 and the process 



controller 211, and a predetermined number of pieces of data are 
transferred. The adequate number of pieces of data is set by the 
process controller 211 so that the busy signal becomes active after 
the transfer is coirpleted. 
5 The transfer control section 601 provides controls for 

transfer so that the sequence of image processing and data for the 
image processing to be added or updated are split into blocks for 
a plurality of transfer times, each by a predetermined number of 
pieces of data to be transferred for one time, and that the blocks 

10 are transferred from the host buffer 507 as the third storage 
section to the program RAM 505 and the data RAM 506 as the second 
storage section. 

A sequence of data transfer from the host buffer 507 to the 
program RAM 505 and the data RAM 506 is explained in detail below 

15 with reference to Fig. 7 and Fig. 8. 

Fig. 8 shows a format of data to be transferred from the 
process controller 211 to the host buffer 507. This data format 
is structured with a header including a target address for transfer, 
a total number of words to be transferred, and a number N of words 

20 to be transferred for one time, and data to be transferred. The 
process controller 211 can set the number N of pieces of data to 
be transferred for one time to an adequate value according to the 
length of idle cycle time determined based on the ability of the 
image processing section 204 to perform image processing. 

25 Fig. 7 shows a process flow of data transfer. When download 
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from the process controller 211 to the host buffer 507 is finished 
(step S701) , it is determined whether this transfer is performed 
for the first time or in progress (step S702) . At the time of 
initial transfer, the target address for transfer, the total number 
of words to be transferred, and the number N of words to be 
transferred for one time are read-in based on the data format shown 
in Fig. 8 (step S703) - The number N of words to be transferred 
for one time represents an optimal n\amber of words to be transferred 
in the image processing apparatus . 

A number of remaining words to be rewritten (which is equal 
to the total number of words to be transferred at the initial time) 
is compared to the number N of words to be transferred for one time 
(step S704) . When the number of remaining words to be rewritten 
is greater than the number N of words to be transferred for one 
time, the transfer is executed for N times and data is written in 
the target address for transfer (step S705, step S706) . The 
address in which the data is being rewritten and the number of 
remaining words to be rewritten are updated (step S707) , and the 
next transfer is waited. At the time of next transfer, the 
processing is started from the flow that the transfer has been 
terminated of the flow chart. 

When the number of remaining words to be rewritten is equal 
to or less than the number N of words to be transferred for one 
time, the transfer is performed for times equivalent.to the number 
of remaining words to be rewritten, and the data is written in the 



target address for transfer (step S708, step S709) , and a 
rewriting-request flag is cleared (step S710), and then the flow 
ends - 

After the data transfer is finished, the transfer control 
5 section 601 restores the connection between the processor array 
section 504 and the program RAM 505/ the data RAM 506 to allow the 
copying operation and the facsimile reception operation to be 
performed in parallel like the controls for the plurality of jobs. 

A timing at which the busy signal sent from the processor 

10 array section 504 becomes inactive is explained below. The image 
processor 204 sequentially processes a plurality of raster-scanned 
line data. As explained above, the processor array section 504 
performs various processing on the image data stored in the group 
of bus switches/local memories 502, and stores again the results 

15 of output in the group of bus switches /local memories 502. 

The processing in the processor array section 504 is allowed 
to be performed at a higher speed than the speed at the time of 
storing the data in the group of bus switches/local memories 502. 
Therefore, there must exist some time (period) , when the processor 

20 array section 504 does not need to perform processing, from the 
end of processing for the current line up to the time when all the 
data for the next line is stored in the group of bus switches/local 
memories 502. It is possible to make the busy signal inactive for 
this time (period) . 

25 The sequence of processing or the data for the processing 
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are transferred at a high speed, therefore, the sequence of the 
processing for facsimile reception and the data for the processing 
can be transferred without interruption of the copying operation 
or the other operation, which allows the program to be added or 
updated. 

[Image data control unit 100/Image data control section 203] 

A general outline of the processing in the image data control 
section 203 that forms the image data control unit 100 is explained 
below- Fig. 9 is a block diagram showing the general outline of 
the processing in the image data control section 203 for the image 
processing apparatus according to the embodiment. 

As shown in the block diagram of Fig. 9, an image data 
input/output section 901 inputs (receives) image data from the 
sensor board unit 202 and outputs (transmits) the iinage data to 
the image processor 204. That is, the image data input/output 
section 901 is a section that makes connections between the image 
reading unit 101 and the image processing unit 103 (image processor 
204) . In other words, the section 901 is an input/output section 
dedicated to transmission of the image data read-out by the image 
reading unit 101 to the ijnage processing unit 103. 

An image data input control section 902 inputs (receives) 
the image data obtained by correcting the scanned image in the image 
processor 204. The input image data is subjected to data 
compression in a data corrpression section 903 in order to enhance 
transmission efficiency in the parallel bus 220. The corrpressed 



data is then sent out to the parallel bus 220 through a data 
conversion section 904 and a parallel data I/F 905. 

The image data received from the parallel bus 220 through 
the parallel data I/F 905 is sent to a data decompression section 
5 906 through the data conversion section 904 because the data has 
been coitpressed for its transmission on the bus, and the image data 
is subjected to data decompression. An image data output control 
section 907 transmits the decorrpressed image data to the image 
processor 204. 

10 The image data control section 203 also has a data conversion 

function between parallel data and serial data. The system 
controller 231 transfers the data to the parallel bus 220, and the 
process controller 211 transfers the data to the serial bus 210. 
The image data control section 203 performs data conversion for 

15 communications between the two controllers. 

The serial data I/F comprises a first serial data I/F 908 
that performs data transaction with the process controller via the 
serial bus 210, and a second serial data I/F 909 used for data 
exchange with the image processor 204 . One system is independently 

20 provided between the image data control section 203 and the image 
processor 204, which allows interface to the image processor 204 
to be executed more smoothly. 

A command control section 910 controls operations of each 
component and each interface in the image data control section 203 

25 according to a received command. 




[Image writing unit 104 /Video data control section 205] 

A general outline of the processing in the video data control 

section 205 that partially forms the image writing unit 104 in the 

image processing apparatus according to the embodiment. Fig. 10 
5 is a block diagram showing the general outline of the processing 

in the video data control section 205 for the image processing 

apparatus according to the embodiment . 

As shown in the block diagram of Fig. 10, the video data 

control section 205 performs additional processing on the input 
•=.3 10 image data according to the characteristics of the image formation 

Li i 

in unit 206. That is, an edge smoothing section 1001 performs 

5^3 re-arrangement of dots through edge smoothing, and a pulse control 

section 1002 controls pulses of image signals to form dots and 
outputs the processed image data to the image formation unit 206. 
'"'f 15 The video data control section 205 has a format conversion 

P ^ 

';t function between parallel data and serial data separately from the 

image-data conversion. Therefore, even the video data control 
section 205 as a discrete device can support communications between 
the system controller 231 and the process controller 211. 

20 That is, the video data control section 205 comprises a 

parallel data I/F 1003 that transmits and receives parallel data, 
a serial data I/F 1004 that transmits and receives serial data, 
and a data conversion section 1005 that converts respective data 
received by the parallel data I/F 1003 and the serial data I/F 1004 

25 to data in the other format. Thus, the formats of both of the data 

31 



• 



can be converted to each other. 

[Image memory control unit 102 /Image-memory access control section 
221] 

A general outline of the processing in the image-memory 
5 access control section 221 that partially forms the image memory 
control unit 102 is explained below. Fig. 11 is a block diagram 
showing the general outline of the processing of the image-memory 
access control section 221 in the image processing apparatus 
according to the embodiment. 

10 As shown in the block diagram of Fig. 11, the image-memory 

access control section 221 manages the interface for image data 
to the parallel bus 220, and controls access, that is, storing 
(writing-in) /reading of the image data in/from the memory module 
222. Further, the image-memory access control section 221 

15 controls decompression of coded data received mainly from an 
external PC 223 to image data. 

Accordingly, the image-memory access control section 221 
coitprises a parallel data I/F 1101, a system controller I/F 1102, 
a memory access control section 1103, a line buffer 1104, a video 

20 control section 1105, a data compression section 1106, a data 
deconpression section 1107, and a data conversion section 1108. 

The parallel data I/F 1101 manages the interface for image 
data to the parallel bus 220. The memory access control section 
1103 controls access, that is, storing (writing-in) /reading of the 

25 image data in/from the memory module 222. 
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The received coded data is stored in a local area of the 
line buffer 1104 . The video control section 1105 decompresses the 
coded data stored in the line buffer 1104 to image data based on 
the instruction for decoirpression received from the system 
controller 231 through the system controller I/F 1102. 

The decompressed image data or the image data received from 
the parallel bus 220 via the parallel data I/F 1101 is stored in 
the memory module 222. In this case, the data conversion section 
1108 selects any image data as an object to be stored, the data 
coirpression section 1106 cortpresses the data to increase the 
efficiency of using the memory, and the memory access control 
section 1103 stores (writes) the image data in the memory module 
222 with management of the addresses in the memory module 222. 

The memory access control section 1103 reads out the image 
data stored (accumulated) in the memory module 222 by controlling 
the target address to be read out, and the data decompression 
section 1107 decompresses the read-out image data. When the 
decompressed image data is to be transferred to the parallel bus 
220, the data transfer is carried out via the parallel data I/F 
1101. 

[Configuration of units] 

The configuration of imits in the image processing apparatus 
according to the embodiment is explained below. Fig. 12 is a block 
diagram showing an example of the configuration of units when the 
image processing apparatus is a digital multifunction machine . 



• m 

Fig. 13 is a block diagram showing an exairple of the configuration 
of units when the linage processing apparatus is a printer as a 
discrete device. 

The digital multifunction machine as shown in Fig. 12 
5 comprises three units: the image reading unit 101, an image engine 
control unit 1200, and the image writing unit 104. Each of the 
units can be managed with a discrete PC board, respectively. 

The image reading wait 101 coitprises a CCD 1201, an A/D 
conversion module 1202, and a gain control module 1203, and converts 
10 optically read-out image information to digital image signals. 

The image engine control unit 1200 is formed mainly with 
the system controller 231, the process controller 211, and the 
memory module 222 in the image memory control unit 102, Further, 
the image processor 204, the image-memory access control section 
15 221, and the image data control section 203 for controlling the 
bus are handled as a grouping of units . 

The image writing unit 104 corrprises the video data control 
section 205 as a main unit, and the image formation unit 206. 

Based on the configuration of these units, when 
20 specifications or performance capabilities of the image reading 
unit 101 are altered, data interface can be retained by changing 
only the image reading unit, 101 in the system of the digital 
multifunction machine. Thus, there is no need to make a change 
to any other units. When the image formation unit (engine) 206 
25 is altered, reconstruction of the system is possible by changing 
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only the image writing unit 104 . 

As explained above, in the case of the units depending on 
the input/output devices, the system is constructed with the units 
which have different configurations. Therefore, the system can 
5 be upgraded only through minimum-unit replacements on condition 
that the data interface is retained. 

When the printer as a discrete device shown in Fig. 13 uses 
the image formation unit (engine) 206 the same as that of the digital 
multifunction machine, the image writing unit 104 can be shared 

10 with the digital multifunction machine. 

When the image processing apparatus is used as a discrete 
printer, there is no need to provide the image reading unit 101. 
Accordingly, the image reading unit 101 is removed from the system 
configuration of the digital multifunction machine. The image 

15 engine control unit 1200 can perform its function even if the unit 
is commonly used with the digital multifunction machine, but the 
function will be beyond the specs. Further, there is no need to 
provide the image processor 204. Therefore, any controller most 
suitable to the system is formed on a different board to enable 

20 cost optimization. 

In the image engine control unit 1200 shown in Fig. 12, 
respective modules (components) of the image processor 204, the 
image data control section 203 and the image-memory access control 
section 221 are formed with independent modules. Accordingly, a 

25 change in usage from the image engine control unit 1200 to a 
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controller is made by removing any unnecessary modules, so that 
the common modules are used for a general purpose. As explained 
above, the module for image engine control and the module for a 
controller are not produced discretely, but the same function can 
be performed by using the common module between the two. 
[Contents of image processing] 

Contents of the image processing of the image processing 
apparatus according to the embodiment is explained below. Fig. 
14 schematically shows a scanner (an exaitple of a spatial filter) 
of the image processing apparatus according to the embodiment . The 
function of MTF correction is performed based on the structure of 
the spatial filter. 

As shown in Fig. 14, when the two-dimensional spatial filter 
is structured with filter factors of A to Y, filtering is executed 
on all of images for input image data with the same computing 
operation. 

When spatial filtering is to be performed around the input 
image data (row i, column j), for exaitple, respective images in 
row i and column j are subjected to computation with the 
corresponding factors. The pixel (i, j) is coirputed with the 
factor value M, and the pixel (i, j+1) is confuted with a factor 
value N, respectively. The result of calculation within a filter 
matrix is output as the result of processing for a remarked pixel 
(i, j). 

When the remarked pixel is (i, j+1) , the pixel (i, j+1) is 



computed with the factor value and the pixel (i, j+2) is computed 
with the factor value N. Thus, the result of calculation within 
the filter matrix is output as the result of processing for the 
remarked pixel (i, j+1) . 

The processing is executed based on different input image 
data but common parameters for processing. In this spatial filter 
processing, the factor values A to Y are not fixed, but can 
arbitrarily be changed according to characteristics of an input 
image and desired image quality . Further, there may be a case where 
flexibility of the image processing function can not be ensured 
unless a change can be made to the values. 

In the image processor 204, even if the factor value is 
downloaded from the process controller, the configuration of the 
scanning unit is altered, and characteristics of degradation in 
the scanned dLmage are changed, changes of the system can be followed 
by changing the contents of data to be loaded. 

Fig. 15 schematically shows shading correction in the image 
processing apparatus according to the embodiment- Fig. 16 
schematically shows data for shading in the image processing 
apparatus according to the embodiment. 

The shading correction is the processing for correcting 
nonuniformity in reflection light characteristics based on a 
illumination distribution of an illumination system. A reference 
white plate with uniform density is scanned before scanning a 
document, reference data for shading correction is generated, and 



a reflection distribution depending on scanned positions of the 
image is normalized. 

As shown in Fig. 16, the reflection distribution of the data 
for shading is different due to a position n where the document 
5 is scanned. The uniform-density white plate is scanned at a dark 
level at the edge of the document scanned position. Sn represents 
a signal level when the white plate is scanned at a data read- 
out position n, and a higher value in Sn indicates that the white 
plate is scanned at a brighter level. 

10 The shading correction is the processing for correcting 

variations in a light-amount distribution of a lamp by executing 
the processing with the same contents on each scanned image data 
for the data dependent on positions. The data S shown in Fig. 15 
is the data for shading generated by scanning the white plate shown 

15 in Fig. 15. 

The data D shown in Fig. 15 is scanned image data for each 
line to be scanned, and n represents a position where data is scanned . 
The data C is data after shading processing is executed on data 
D, and the data is normalized by the following equation. 

20 Cn = A (Dn/Sn) 

Where A is a factor of normalization. 

The image processor 204 stores the data S in the group of 
bus switches /local memories 502, and performs computing for 
correction between Dn and Sn corresponding to the input data D. 

25 [Data flow] 



Processing for accuinulating images in the memory module 222 
is explained below. Fig. 17 and Fig. 18 show data flows of the 
image processing apparatus as a digital multifunction machine with 
the processing for accumulating images in the memory module 222 
according to the embodiment. 

Fig. 17 shows a flow from the scanning unit 201 to the memory 
module 222, and Fig. 18 shows a flow from the memory module 222 
to the image formation unit 206 . Each of the processing is executed 
by controlling the data flow between the buses and units under the 
control of the image data control section 203. 

As shown in Fig. 17, the scanning unit 201 and the sensor 
board unit 202 provide controls for scanning (step S1701) . The 
image data control section 203 performs input processing of image 
data and provides controls for its output (step S1702) . The image 
processor 204 performs processing for input I/F control (step 
S1703) , the scanner imaging (step S1704) , and output 1/F processing 
(step S1705) . 

The image data control section 203 performs again the 
processing for inputting image data (step S1706) , data cortpression 
(step S1707) and data conversion (step S1708), and then performs 
the processing for parallel 1/F controls (step S1709) . 

The image-memory access control section 221 provides 
controls for the parallel I/F (step S1710), performs data 
conversion (stepS1711) and further data compression (stepS1712), 
and provides controls for access to the memory module 222 (step 



S1713) , Accordingly, the image data is stored in the memory module 
222 (step S1714) . 

As shown in Fig. 18, the image-memory access control section 
221 provides controls for access (step S1802) to the image data 
stored in the memory module 222 (step SlBOl) , performs data 
decompression (step S1803) and data conversion (stepS1804), and 
provides controls for the parallel I/F (step S1805) . 

The image data control section 203 provides controls for 
the parallel I/F (step S1806) , performs data conversion (step 
S1807) and data decompression (step S1808), and then provides 
output controls for the image data (step S1809) . 

The image processor 204 provides controls for the input I/F 
(step S1810) , performs the processing for image quality on the data 
(stepSlSll), and provides controls for the output I/F (stepS1812) . 

The video data control section 205 performs edge smoothing 
on the image data (step S1813) and provides pulse controls (step 
S1814) , and the image formation unit 206 executes the processing 
for image formation (step S1815) . 

The scanner imaging is executed on the scanned image data 
and the processing for image quality is executed on the image data 
to be output to the image formation unit 206, and both of the 
processing are discretely performed in the image processor 204. 

The scanner imaging and the image-quality processing are 
concurrently operable. The scanned image is provided for 
facsimile transmission, and at the same time, the image data 
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previously accumulated in the memory module 222 can be output onto 
the transfer paper while changing the contents of the image-quality 
processing. 

Fig. 19 and Fig. 20 show the data flows of the image 
processing apparatus as a discrete printer with the processing for 
accumulating images in the memory module 222 according to the 
embodiment. Fig. 19 shows the flow from the PC 223 to the memory 
module 222, and Fig. 20 shows the flow from the memory module 222 
to the image formation unit 206. 

As shown in Fig. 19, the PC 223 outputs the image data (step 
S1901), and the image-memory access control section 221 retains 
the image data in the line buffer 1104 (step S1902) , provides video 
controls (step S1903), data conversion (step S1904) and data 
compression (step S1905) , and then provides controls for access 
to the memory module 222 (step S1906) . Accordingly, the image data 
is stored in the memory module 222 . 

In Fig. 20, the image-memory access control section 221 
provides controls for access (step S2002) to the image data stored 
in the memory module 222 (step S2001) , performs data decorrpression 
(step S2003) and data conversion (step S2004), and provides 
controls for the parallel I/F (step S2005) . 

The video data control section 205 performs edge smoothing 
on the image data (step S2006) and provides pulse controls (step 
S2007) , and the image formation unit 206 executes the processing 
for image formation (step S2008) . 



As explained above, the coded data sent from the PC 223 is 
converted to image data, and once the image data is accumulated 
in the memory module 222, data deconpression is performed only once 
even if a plurality of copies are to be output. Thus, printing 
performance is iirproved as coitpared to the controller that performs 
data decoirpression every time. 

As for the image data read-out from the memory module 222, 
a reproduction image with a plurality of variations for one image 
can be formed on transfer paper by changing the contents of the 
post-processing executed in the video data control section 205. 
Further, there is no need to decompress the coded data to image 
data each time the parameters of edge smoothing and pulse controls 
in the video data control section 205 are altered. 
[Configuration of facsimile control unit 224] 

A functional configuration of the facsimile control unit 
224 is explained below. Fig. 21 is a block diagram showing a 
configuration of the facsimile control unit 224 in the image 
processing apparatus according to the embodiment. 

As shown in the block diagram of Fig. 21, the facsimile 
control unit 224 comprises a facsimile transmission/reception 
section 2101 and an external I/F 2102. The facsimile 
transmission/reception section 2101 converts the image data to its 
communication format, transmits the data to an external network, 
and restores the data received from the outside to the image data, 
and the image formation unit 206 prints out the data via the external 




I/F 2102 and the parallel bus 220. 

The facsimile transmission/reception section 2101 
comprises a facsimile imaging section 2103, an image memory 2104, 
a memory control section 2105, a data control section 2106, an image 
5 compression/decompression section 2107, a modem 2108, and a 
network control device 2109. 

As for the facsimile imaging of the above processing, the 
processing for binary smoothing is executed on the received image 
in the edge smoothing section 1001 of the video data control section 

10 205 shown in Fig. 10. The function of the output buffer in the 
image memory 2104 is partially shifted to the image-memory access 
control section 221 and the memory module 222. 

In the facsimile transmission/reception section 2101 
configured as explained above, when transmission of the image data 

15 is started, the data control section 2106 issues an instruction 
to the memory control section 2105 to successively read out the 
accumulated linage data from the image memory 2104. The read-out 
image data is restored to original signals by the facsimile imaging 
section 2103, the processing for density conversion and scaling 

20 are executed on the signals, and the image data is added to the 
data control section 2106. 

The image data added to the data control section 2106 is 
code-compressed by the image coirpression/decorrpression section 
2107, and demodulated in the modem 2108, and then the demodulated 

25 data is sent to the target for transfer via the network control 
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device 2109. The image information that has been transmitted is 

deleted from the image memory 2104. 

Reception images are accumulated once in the image memory 

2104 on their reception. If the situation allows reception images 
5 to be printed out during accumulation, an image is printed out at 

the point of time when the image for one sheet is completely received. 

When reception is started in response to being called during copying, 

images are accumulated in the image memory 2104 until the percentage 

of using the image memory 2104 reaches a predetermined value, 80%, 
:i 10 for example. When the percentage of using the image memory 2104 

In has reached 80%, the writing operation executed at that time is 

£3 terminated, and the reception image is read out from the image 

£D memory 2104 to be printed out. 

£3 The reception image read-out from the image memory 2104 is 

£3 15 then deleted from the image memory 2104. When the percentage of 

£3 using the image memory 2104 has been decreased to a predetermined 

value, 10%, for exairple, the terminated writing operation is 
restarted, and when all the writing operation is finished, the 
remaining part of the reception image is printed out. Various 
20 types of parameters for the writing operation are internally saved 
during its termination so that the writing operation can be 
restarted after its termination is released. At the time of 
restarting, the parameters are internally recovered. 
[Configuration of SIMD type of processor] 
25 Fig. 22 schematically shows a configuration of an SIMD type 



of processor. SIMD (Single Instruction stream Multiple Data 
stream) allows the processor to concurrently execute a single 
instruction on a plurality pieces of data. Accordingly, the 
processor coitprises a plurality of PEs (processor elements) . 

Each of the PEs corrprises a register (Reg) 2201 that stores 
data, a multiplexer (MUX) 2202 that gets access to any register 
of another PE, a barrel shifter (Shift Expand) 2203, an arithmetic 
logic unit (ALU) 2204, an accumulator (A) 2205 that stores logical 
results, and a teirporary register (F) 220 6 that teirporarily 
coirpares the contents of the acc\miulator to each other. 

Each of the registers 2201 is connected to an address bus 
and a data bus (a lead and a word line) , and stores an instruction 
code to define processing and data as an object for processing. 
The contents of the register 2201 is input into the arithmetic logic 
unit 2204, and the result of arithmetic is stored in the accumulator 
2205. 

In order to take out the result to the outside of the PE, 
the result is saved once in the temporary register 2206 . The result 
of the processing for the target data can be obtained by fetching 
the contents of the temporary register 2206, 

An instruction code with the same contents is provided to 
the respective PEs, and the target data for processing is provided 
to each PE in its different state. The result of arithmetic is 
subjected to parallel processing by referring to the contents of 
registers 2201 in adjacent PEs in the multiplexer 2202, and the 




result is output to each accimulator 2205. 

For exaitple, if the contents of one line in the image data 
is provided in PE for each pixel and the contents are calculated 
with the same instruction code, the result of processing for one 
5 line can be obtained within a shorter period of time as coirpared 
to sequential processing for each pixel. Especially, for the 
processing of spatial filtering and shading correction, an 
operation equation itself is used as an instruction code for each 
PE, so that the processing common to all the PEs can be executed. 
10 The method for image processing explained in this embodiment 

in can be realized by making a coirputer such as a personal coirputer 

C3 or a work station execute a previously prepared program. This 

£3 program is recorded in a computer-readable recording medium such 

^3 as a hard disk, a floppy disk, a CD-ROM, MO, and a DVD, and the 

^■y' 15 program is read out from the recording medium by the coitputer to 

li be executed. Further, this program can be distributed via the 

recording medium and a network such as the Internet, and can also 
be transferred as a transmission medium. 

According to one aspect of this invention, during idle cycle 
20 time that the image processing section does not execute image 
processing, the transfer control section splits a sequence of image 
processing and data for image processing to be added or updated 
into blocks for a plurality of transfer times, and transfers the 
blocks from the third storage section to the second storage section. 
25 Therefore, alteration of and addition to the program can 



immediately and efficiently be executed as required without 
interruption of the primary operation of the image processing 
apparatus. Thus, the image processing apparatus with high 
efficiency and availability can be obtained. 
5 Further, during the idle cycle time that the image processing 

section does not execute image processing, the transfer control 
section splits the sequence of image processing and data for image 
processing to be added or updated into blocks for a plurality of 
transfer times each by a predetermined number of pieces of data 
3 10 to be transferred for one time, and transfers the blocks from the 

in third storage section to the second storage section. Therefore, 

S3 alteration of and addition to the program can immediately and 

P efficiently be executed as required without interruption of the 

primary operation of the image processing apparatus. Thus, the 
'^^ 15 image processing apparatus with high efficiency and availability 

;Z, can be obtained. 

Further, a set value of the predetermined number of pieces 
of data to be transferred for one time is included in data downloaded 
from the external microprocessor into the third storage section, 
20 and is set according to the length of idle cycle time determined 
based on the ability of the image processing section to perform 
image processing. Therefore, the sequence of image processing and 
data for image processing to be added or updated can efficiently 
be transferred from the third storage section to the second storage 
25 section under optimal transfer conditions suitable for the ability 




of the image processing section to perform image processing. 
Further, such transfer can be executed without interruption of the 
primary operation of the image processing apparatus. Thus, the 
image processing apparatus with high efficiency and availability 
5 , can be obtained. 

Further, the image processing unit is formed with the SIMD 
type of processor to perform image processing based on a high- 
speed computation of the SIMD type of processor. Therefore, 
respective resources in the system can be made effective use of 

10 when a multiple function is performed. Thus, the image processing 
apparatus that can provide most adequate controls for the overall 
system can be obtained. 

According to another aspect of this invention, the sequence 
of image processing and data for image processing to be added or 

15 updated are split into blocks for a plurality of transfer times, 
and the blocks are transferred from a third storage section to a 
second storage section during idle cycle time that the image 
processing section does not execute image processing- Therefore, 
an image processing apparatus can immediately and efficiently 

20 execute alteration of and addition to the program as required 
without interruption of the primary operation of the image 
processing apparatus. Thus, the method of adding or updating the 
sequence of image processing and the data for image processing in 
the image processing apparatus with such functions can be obtained. 

25 Further, the sequence of image processing and data for image 

48 



processing to be added or updated are split into blocks for a 
plurality of transfer times each by a predetenuined number of pieces 
of data to be transferred for one time, and the blocks are 
transferred from the third storage section to the second storage 
5 section during idle cycle time that the image processing section 
does not execute image processing. Therefore, an image processing 
apparatus can immediately and efficiently execute alteration of 
and addition to the program as required without interruption of 
the primary operation of the linage processing apparatus. Thus, 
Q 10 the method of adding or updating the sequence of image processing 

In and the data for image processing in the image processing apparatus 

£3 with such functions can be obtained. 

^3 Further, a set value of the predetermined number of pieces 

of data to be transferred for one time is included in data downloaded 
Jf 15 from the external microprocessor into the third storage section, 

li and is set according to the length of idle cycle time determined 

based on the ability of the image processing section to perform 
image processing- Therefore, an image processing apparatus can 
efficiently transfer the sequence of image processing and data for 
20 image processing to be added or updated from the third storage 
section to the second storage section under optimal transfer 
conditions suitable for the ability of the image processing section 
to perform image processing. Further, such transfer can be 
executed without interruption of the primary operation of the image 
25 processing apparatus . Thus, the method for adding or updating the 




sequence of image processing and the data for image processing in 
the image processing apparatus with such functions can be obtained. 

According to still another aspect of this invention, a 
program which makes a cortputer execute the method according to the 
5 invention is recorded in a recording medium, which allows the 
program to be machine-readable. Accordingly, it is possible to 
obtain the recording medium with which the method according to the 
invention can be executed by a computer. 

The present document incorporated by reference the entire 
10 contents of Japanese priority document, 11-248307 filed in Japan 
on September 2, 1999. 

Although the invention has been described with respect to 
a specific embodiment for a complete and clear disclosure, the 
appended claims are not to be thus limited but are to be construed 
15 as embodying all modifications and alternative constructions that 
may occur to one skilled in the art which fairly fall within the 
basic teaching herein set forth. 
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